# Tektronix 4052/4054 opcode Decoding table (gray cells 6800 unused, red on 4052/4054&A, 4052A/4054A ONLY=blue + green 6800 16-bit ext)

| MSB \ LSB | _0             | _1               | _2               | _3              | _4               | _5              | _6             | _7              | _8              | _9             | _A              | _B              | _C              | _D              | _E            | _F              |
|-----------|----------------|------------------|------------------|-----------------|------------------|-----------------|----------------|-----------------|-----------------|----------------|-----------------|-----------------|-----------------|-----------------|---------------|-----------------|
| 0_        | TEST<br>(INH)  | NOP<br>(INH)     | NOP<br>(INH)     | SFA<br>(INH)    | LDAG D<br>(DIR)  | LDAG X<br>(DIR) | TAP<br>(INH)   | TPA<br>(INH)    | INX<br>(INH)    | DEX<br>(INH)   | CLV<br>(INH)    | SEV<br>(INH)    | CLC<br>(INH)    | SEC<br>(INH)    | CLI<br>(INH)  | SEI<br>(INH)    |
| 1_        | SBA<br>(INH)   | CBA<br>(INH)     | TAPX<br>(INH)    | TPAX<br>(INH)   | ADXI I<br>(IMM)  | ASPI I<br>(IMM) | TAB<br>(INH)   | TBA<br>(INH)    | SDA<br>(INH)    | DAA<br>(INH)   | LDXX<br>(INH)   | ABA<br>(ACC)    | LDAX<br>(INH)   | LDBX<br>(INH)   | STAX<br>(INH) | JMPAX<br>(INH)  |
| 2_        | BRA<br>(REL)   | SDB<br>(INH)     | BHI<br>(REL)     | BLS<br>(REL)    | BCC<br>(REL)     | BCS<br>(REL)    | BNE<br>(REL)   | BEQ<br>(REL)    | BVC<br>(REL)    | BVS<br>(REL)   | BPL<br>(REL)    | BMI<br>(REL)    | BGE<br>(REL)    | BLT<br>(REL)    | BGT<br>(REL)  | BLE<br>(REL)    |
| 3_        | TSX<br>(INH)   | INS<br>(INH)     | PUL A<br>(ACC)   | PUL B<br>(ACC)  | DES<br>(INH)     | TXS<br>(INH)    | PSH A<br>(ACC) | PSH B<br>(ACC)  | JMPIN<br>(EXT)  | RTS<br>(INH)   | FPSH D<br>(DIR) | RTI<br>(INH)    | FPSH X<br>(IDX) | FPSH<br>(EXT)   | WAI<br>(INH)  | SWI<br>(INH)    |
| 4_        | NEG A<br>(ACC) | FPSH I<br>(IMM*) | FPUL D<br>(DIR)  | COM A<br>(ACC)  | LSR A<br>(ACC)   | FPUL X<br>(IDX) | ROR A<br>(ACC) | ASR A<br>(ACC)  | ASL A<br>(ACC)  | ROL A<br>(ACC) | DEC A<br>(ACC)  | FPUL<br>(EXT)   | INC A<br>(ACC)  | TST A (ACC)     | FDUP<br>(INH) | CLR A<br>(ACC)  |
| 5_        | NEG B<br>(ACC) | FSWAP<br>(INH)   | FADD<br>(INH)    | COM B<br>(ACC)  | LSR B<br>(ACC)   | FSUB<br>(INH)   | ROR B<br>(ACC) | ASR B<br>(ACC)  | ASL B<br>(ACC)  | ROL B<br>(ACC) | DEC B<br>(ACC)  | FMUL<br>(INH)   | INC B<br>(ACC)  | TST B (ACC)     | FDIV<br>(INH) | CLR B<br>(ACC)  |
| 6_        | NEG X<br>(IDX) | FNRM<br>(INH)    | PSHRET<br>(DIR)  | COM<br>(IDX)    | LSR<br>(IDX)     | RTRN<br>(DIR)   | ROR<br>(IDX)   | ASR<br>(IDX)    | ASL<br>(IDX)    | ROL<br>(IDX)   | DEC<br>(IDX)    | PSHX<br>(INH)   | INC<br>(IDX)    | TST<br>(IDX)    | JMP<br>(IDX)  | CLR<br>(IDX)    |
| 7_        | NEG<br>(EXT)   | STRK<br>(INH)    | VECT<br>(INH)    | COM<br>(EXT)    | LSR<br>(EXT)     | PULX<br>(INH)   | ROR<br>(EXT)   | ASR<br>(EXT)    | ASL<br>(EXT)    | ROL<br>(EXT)   | DEC<br>(EXT)    | STAG D<br>(DIR) | INC<br>(EXT)    | TST<br>(EXT)    | JMP<br>(EXT)  | CLR<br>(EXT)    |
| 8_        | SUB A<br>(IMM) | CMP A<br>(IMM)   | SBC A<br>(IMM)   | STAG X<br>(IDX) | AND A<br>(IMM)   | BIT A<br>(IMM)  | LDA A<br>(IMM) | ADDG D<br>(DIR) | EOR A<br>(IMM)  | ADC A<br>(IMM) | ORA A<br>(IMM)  | ADD A<br>(IMM)  | CPX A<br>(IMM)  | BSR<br>(REL)    | LDS<br>(IMM)  | ADDG X<br>(IDX) |
| 9_        | SUB A<br>(DIR) | CMP A<br>(DIR)   | SBC A<br>(DIR)   | SUBD G<br>(DIR) | AND A<br>(DIR)   | BIT A<br>(DIR)  | LDA A<br>(DIR) | STA A<br>(DIR)  | EOR A<br>(DIR)  | ADC A<br>(DIR) | ORA A<br>(DIR)  | ADD A<br>(DIR)  | CPX A<br>(DIR)  | SUBD X<br>(IDX) | LDS<br>(DIR)  | STS<br>(DIR)    |
| A_        | SUB A<br>(IDX) | CMP A (IDX)      | SBC A (IDX)      | INXSTX<br>(DIR) | AND A<br>(IDX)   | BIT A<br>(IDX)  | LDA A<br>(IDX) | STA A<br>(IDX)  | EOR A<br>(IDX)  | ADC A<br>(IDX) | ORA A<br>(IDX)  | ADD A<br>(IDX)  | CPX A<br>(IDX)  | JSR<br>(IDX)    | LDS<br>(IDX)  | STS<br>(IDX)    |
| B_        | SUB A<br>(EXT) | CMP A<br>(EXT)   | SBC A<br>(EXT)   | LDAG<br>(EXT)   | AND A<br>(EXT)   | BIT A<br>(EXT)  | LDA A<br>(EXT) | STA A<br>(EXT)  | EOR A<br>(EXT)  | ADC A<br>(EXT) | ORA A<br>(EXT)  | ADD A<br>(EXT)  | CPX A<br>(EXT)  | JSR<br>(EXT)    | LDS<br>(EXT)  | STS<br>(EXT)    |
| C_        | SUB B<br>(IMM) | CMP B (IMM)      | SBC B (IMM)      | STAG<br>(EXT)   | AND B<br>(IMM)   | BIT B<br>(IMM)  | LDA B<br>(IMM) | C7-ESC          | EOR B<br>(IMM)  | ADC B<br>(IMM) | ORA B<br>(IMM)  | ADD B<br>(IMM)  | ADAX<br>(INH)   | WAGDX<br>(INH)  | LDX<br>(IMM)  |                 |
| D_        | SUB B<br>(DIR) | CMP B<br>(DIR)   | SBC B (DIR)      | LDAG I<br>(EXT) | AND B<br>(DIR)   | BIT B<br>(DIR)  | LDA B<br>(DIR) | STA B<br>(DIR)  | EOR B<br>(DIR)  | ADC B<br>(DIR) | ORA B<br>(DIR)  | ADD B<br>(DIR)  | SBUG<br>(INH)   | CBUG<br>(INH)   | LDX<br>(DIR)  | STX<br>(DIR)    |
| E_        | SUB B<br>(IDX) | CMP B (IDX)      | SBC B (IDX)      | MOVLR<br>(INH)  | AND B<br>(IDX)   | BIT B<br>(IDX)  | LDA B<br>(IDX) | STA B<br>(IDX)  | EOR B<br>(IDX)  | ADC B<br>(IDX) | ORA B<br>(IDX)  | ADD B<br>(IDX)  | MOVRL<br>(INH)  | WADX<br>(EXTI)  | LDX<br>(IDX)  | STX<br>(IDX)    |
| F_        | SUB B<br>(EXT) | CMP B<br>(EXT)   | SBC B<br>(EXT)   | CPCH<br>(INH)   | AND B<br>(EXT)   | BIT B<br>(EXT)  | LDA B<br>(EXT) | STA B<br>(EXT)  | EOR B<br>(EXT)  | ADC B<br>(EXT) | ORA B<br>(EXT)  | ADD B<br>(EXT)  | FC-ESC          | PCH<br>(IMM)    | LDX<br>(EXT)  | STX<br>(EXT)    |
| FC_       | PSHG<br>(INH)  | PULG<br>(INH)    | ADDG I<br>(EXTI) | ADDG<br>(EXT)   | SUBG I<br>(EXTI) | SUBG<br>(EXT)   | CMPGX<br>(INH) | CMPSYM<br>(INH) | LDAGX<br>(INH)  | STAGX<br>(INH) |                 |                 |                 |                 |               |                 |
| C7_       | TGX<br>(INH)   | TXG<br>(INH)     | CLRGH<br>(INH)   | IFLOAT<br>(INH) | FIXRND<br>(INH)  | TMULT<br>(INH)  | BUFIN<br>(INH) | BUFOUT<br>(INH) | SEABNK<br>(INH) | DEVIN<br>(INH) | DEVOUT<br>(INH) |                 |                 |                 |               |                 |

# **Abbreviations:**

### 4052/4054 and 4052A/4054A Addressing modes (same as 6800):

#### ACC - Accumulator

In accumulator addressing, either accumulator A or accumulator B is specified. These are 1- byte instructions.

Ex: ABA adds the contents of accumulators and stores the result in accumulator A

#### IMM - Immediate

In immediate addressing, operand is located immediately after the opcode in the second byte of the instruction in program memory (except LDS and LDX where the operand is in the second and third bytes of the instruction). These are 2-byte or 3-byte instructions.

Ex: LDAA #\$25 loads the number (25)H into accumulator A

#### **DIR** - Direct

In direct addressing, the address of the operand is contained in the second byte of the instruction. Direct addressing allows the user to directly address the lowest 256 bytes of the memory, i.e, locations 0 through 255. Enhanced execution times are achieved by storing data in these locations. These are 2-byte instructions.

Ex: LDAA \$25 loads the contents of the memory address (25)<sub>H</sub> into accumulator A

#### **EXT** - Extended

In extended addressing, the address contained in the second byte of the instruction is used as the higher eight bits of the address of the operand. The third byte of the instruction is used as the lower eight bits of the address for the operand. This is an absolute address in the memory. These are 3-byte instructions.

Ex: LDAA \$1000 loads the contents of the memory address (1000)H into accumulator A

### IDX - Indexed

In indexed addressing, the address contained in the second byte of the instruction is added to the index register's lowest eight bits. The carry is then added to the higher order eight bits of the index register. This result is then used to address memory. The modified address is held in a temporary address register so there is no change to the index register. These are 2-byte instructions.

#### Ex: LDX #\$1000 or LDAA \$10.X

Initially, LDX #\$1000 instruction loads  $1000_H$  to the index register (X) using immediate addressing. Then LDAA  $\$10_X$  instruction, using indexed addressing, loads the contents of memory address ( $10_{H} + X = 1010_{H}$  into accumulator A.

#### **INH** - Implied (Inherent)

In the implied addressing mode, the instruction gives the address inherently (i.e., stack pointer, index register, etc.). Inherent instructions are used when no operands need to be fetched. These are 1-byte instructions.

Ex: INX increases the contents of the Index register by one. The address information is "inherent" in the instruction itself.

**INCA** increases the contents of the accumulator A by one.

**DECB** decreases the contents of the accumulator B by one.

### **REL** - Relative

The relative addressing mode is used with most of the branching instructions on the 6802 microprocessor. The first byte of the instruction is the opcode. The second byte of the instruction is called the *offset*. The offset is interpreted as a *signed 7-bit number*. If the MSB (most significant bit) of the offset is 0, the number is positive, which indicates a forward branch. If the MSB of the offset is 1, the number is negative, which indicates a backward branch. This allows the user to address data in a range of -126 to +129 bytes of the present instruction. These are 2-byte instructions.

#### Ex:

PC Hex Label Instruction 0009 2004 BRA 0FH

Data Space - A 0x0000-FFFF 56KB of DRAM + 8KB of DATA ROM

Fetch Space - B 0x0000-FFFF 48KB of BASIC ROM at 0x4000-0xFFFF plus 16KB of bank switched BASIC or option ROM Pack at 0x0000

### 6800, 4052/4054 &A and 4052A/4054A only registers:

- ACCA Accumulator A
  - Extended to 16-bits
  - ACCA is low order 8 bits
- ACCG is 16-bit extension of A where A is low order 8-bits
- ACCB Accumulator B
  - Extended to 16-bits
  - o ACCB is low order 8 bits
- ACCX is Accumulator ACCA or ACCB
- X Index register (XH and XL)
- PC Program Counter (PCH and PCL)
- **SP** Stack Pointer (SPH and SPL)
- CC Status register

## CC status register:

| Bit 0 | <b>C</b> Carry/Borrow status            |
|-------|-----------------------------------------|
| Bit 1 | V Two's complement / overflow indicator |
| Bit 2 | <b>Z</b> Zero status                    |
| Bit 3 | N Sign/Negative status                  |
| Bit 4 | I Interrupt Mask status                 |
| Bit 5 | <b>H</b> Half carry                     |
| Bit 6 | D Data Space Indicator (1 → A)          |
| Bit 7 | F Fetch Space Indicator (1 → B)         |

# Symbols in the STATUSES column:

- (blank) operation does not affect status
- x operation affects status
- **0** flag is cleared by the operation
- 1 flag is set by the operation

data8 8-bit immediate data
data16 16-bit immediate data
addr8 8-bit direct address
addr16 16-bit extended address
disp 8-bit signed address displacement

- (HI) bits 15-8 from 16bit value
- (LO) bits 7-0 from 16bit value
- [...] content of ...
- [[...]] implied addressing (content of [content of ...])
- ∧ Logical AND
- v Logical OR
- ¥ Logical Exclusive-OR
- ← Data is transferred in the direction of the arrow



Figure 1- 4052/4054 and 4052A/4054A Registers

# 6800 OPCODE DETAILS

| MNEMO | SYNTAX                      | MODE       | BYTES | CODE | CYCLES | С | Z | S | 0 | Ac | ı | SYMBOLIC OPERATION                                                      | DESCRIPTION                            |
|-------|-----------------------------|------------|-------|------|--------|---|---|---|---|----|---|-------------------------------------------------------------------------|----------------------------------------|
| ABA   | ABA                         | ACC        | 1     | \$1B | 2      | х | х | x | х | х  | - | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] + [ <u>B</u> ]                       | Add <u>B</u> to <u>A</u>               |
|       | ADC <u>A</u> # <u>data8</u> | <u>IMM</u> | 2     | \$89 | 2      |   |   |   |   |    |   | [ <u>A] ←</u> [ <u>A]</u> + <u>data8</u> + C                            |                                        |
|       | ADC <u>A</u> addr8          | DIR        | 2     | \$99 | 3      |   |   |   |   |    |   | [ <u>A</u> ] ← [ <u>A</u> ] + [ <u>addr8</u> ] + C                      |                                        |
|       | ADC <u>A</u> data8,X        | <u>IDX</u> | 2     | \$A9 | 5      |   |   |   |   |    |   | [A] ← [A] + [data8 + [X]] + C                                           |                                        |
| ADC   | ADC A addr16                | EXT        | 3     | \$B9 | 4      |   |   |   |   |    |   | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] + [ <u>addr16</u> ] + C              | Add contents of Memory +               |
| ADC   | ADC <u>B</u> # <u>data8</u> | <u>IMM</u> | 2     | \$C9 | 2      | X | X | X | X | X  | - | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] + <u>data8</u> + C                   | Carry Flag to Accumulator              |
|       | ADC B addr8                 | DIR        | 2     | \$D9 | 3      |   |   |   |   |    |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] + [ <u>addr8</u> ] + C               |                                        |
|       | ADC <u>B</u> data8,X        | IDX        | 2     | \$E9 | 5      |   |   |   |   |    |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] + [ <u>data8</u> + [ <u>X</u> ]] + C |                                        |
|       | ADC B addr16                | EXT        | 3     | \$F9 | 4      |   |   |   |   |    |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] + [ <u>addr16</u> ] + C              |                                        |
|       | ADD <u>A</u> # <u>data8</u> | <u>IMM</u> | 2     | \$8B | 2      |   |   |   |   |    |   | [A] <u>←</u> [A] + <u>data8</u>                                         |                                        |
| ADD   | ADD <u>A</u> addr8          | DIR        | 2     | \$9B | 3      | х | x | x | x | x  | - | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] + [ <u>addr8</u> ]                   | Add Memory contents to the Accumulator |
|       | ADD <u>A</u> data8,X        | <u>IDX</u> | 2     | \$AB | 5      |   |   |   |   |    |   | [A] ← [A] + [data8 + [X]]                                               |                                        |

|     | ADD <u>A</u> addr16         | EXT        | 3 | \$BB | 4 |   |           |          |          |   |   | [A] ← [A] + [addr16]                                                |                                |
|-----|-----------------------------|------------|---|------|---|---|-----------|----------|----------|---|---|---------------------------------------------------------------------|--------------------------------|
|     | ADD <u>B</u> # <u>data8</u> | <u>IMM</u> | 2 | \$CB | 2 |   |           |          |          |   |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] + <u>data8</u>                   |                                |
|     | ADD <u>B</u> addr8          | DIR        | 2 | \$DB | 3 |   |           |          |          |   |   | [B] ← [B] + [addr8]                                                 |                                |
|     | ADD <u>B</u> data8,X        | <u>IDX</u> | 2 | \$EB | 5 |   |           |          |          |   |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] + [ <u>data8</u> + [ <u>X</u> ]] |                                |
|     | ADD <u>B</u> addr16         | EXT        | 3 | \$FB | 4 |   |           |          |          |   |   | [ <u>B</u> ] ← [ <u>B</u> ] + [ <u>addr16</u> ]                     |                                |
|     | AND <u>A</u> # <u>data8</u> | <u>IMM</u> | 2 | \$84 | 2 |   |           |          |          |   |   | [A] <u>←</u> [A] <u>∧</u> <u>data8</u>                              |                                |
|     | AND <u>A</u> addr8          | DIR        | 2 | \$94 | 3 |   |           |          |          |   |   | [A] ← [A] <u>∧</u> [addr8]                                          |                                |
|     | AND <u>A</u> <u>data8,X</u> | <u>IDX</u> | 2 | \$A4 | 5 |   |           |          |          |   |   | [A] ← [A] <u>∧</u> [data8 + [X]]                                    |                                |
|     | AND <u>A</u> addr16         | <u>EXT</u> | 3 | \$B4 | 4 |   |           |          |          |   |   | [ <u>A] ←</u> [ <u>A] ∧ [addr16]</u>                                | Memory contents AND the        |
| AND | AND <u>B</u> # <u>data8</u> | <u>IMM</u> | 2 | \$C4 | 2 | - | X         | X        | 0        | - | - | [B] ← [B] <u>∧</u> data8                                            | Accumulator to the Accumulator |
|     | AND <u>B</u> addr8          | <u>DIR</u> | 2 | \$D4 | 3 |   |           |          |          |   |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] <u>∧</u> [ <u>addr8</u> ]        |                                |
|     | AND B data8,X               |            | 2 | \$E4 | 5 |   |           |          |          |   |   | <br>[B] ← [B] ∆ [data8 + [X]]                                       |                                |
|     | AND <u>B addr16</u>         | EXT        | 3 | \$F4 | 4 |   |           |          |          |   |   | [B] ← [B] <u>∧</u> [addr16]                                         |                                |
|     | 7.112 <u>D addi 10</u>      |            |   | Ψιι  |   |   | $\forall$ | $\dashv$ | $\dashv$ |   |   | [크] <u> [편] 17 [8888110]</u>                                        |                                |
| ASL | ASL <u>A</u>                | <u>ACC</u> | 1 | \$48 | 2 | х | х         | X        | х        | - | - |                                                                     |                                |

|     | ASL <u>B</u>       | ACC        | 1 | \$58 | 2 |   |   |   |   |   |   |                                                                                              |                                                                |
|-----|--------------------|------------|---|------|---|---|---|---|---|---|---|----------------------------------------------------------------------------------------------|----------------------------------------------------------------|
|     | ASL <u>data8,X</u> | IDX        | 2 | \$68 | 7 |   |   |   |   |   |   | C ← 76543210 ← 0                                                                             | Arithmetic Shift Left. Bit 0 is set to 0. (multiplying by two) |
|     | ASL <u>addr16</u>  | EXT        | 3 | \$78 | 6 |   |   |   |   |   |   |                                                                                              | ,                                                              |
|     | ASR <u>A</u>       | ACC        | 1 | \$47 | 2 |   |   |   |   |   |   |                                                                                              |                                                                |
|     | ASR <u>B</u>       | <u>ACC</u> | 1 | \$57 | 2 |   |   |   |   |   |   |                                                                                              |                                                                |
| ASR | ASR <u>data8,X</u> | IDX        | 2 | \$67 | 7 | X | x | x | x | - | - | 76543210 → <b>C</b>                                                                          | Arithmetic Shift Right. Bit 7 stays the same.                  |
|     | ASR <u>addr16</u>  | EXT        | 3 | \$77 | 6 |   |   |   |   |   |   |                                                                                              |                                                                |
| ВСС | BCC disp           | REL        | 2 | \$24 | 4 | - | - | - | - | - | - | $(C == 0) ?$ $\{ [PC] \leftarrow [PC] + \underline{disp} + 2 \}$                             | Branch if carry clear                                          |
| BCS | BCS disp           | REL        | 2 | \$25 | 4 | - | - | - | - | - | - | (C == 1) ?<br>{[ <u>PC] ← [PC]</u> + <u>disp</u> + 2}                                        | Branch if carry set                                            |
| BEQ | BEQ <u>disp</u>    | REL        | 2 | \$27 | 4 | - | - | - | _ | _ | _ | (Z == 1) ?<br>{[ <u>PC</u> ] ← [ <u>PC</u> ] + <u>disp</u> + 2}                              | Branch if equal to zero                                        |
| BGE | BGE disp           | REL        | 2 | \$2C | 4 | - | - | - | _ | _ | _ | (S ⊻ O == 0) ?<br>{[ <u>PC</u> ] <u>← [PC]</u> + <u>disp</u> + 2}                            | Branch if greater than or equal to zero                        |
| BGT | BGT <u>disp</u>    | REL        | 2 | \$2E | 4 | - | - | - | _ | - | - | (Z <u>∨</u> (S <u>∨</u> O) == 0) ?<br>{[ <u>PC]</u> <u>←</u> [ <u>PC]</u> + <u>disp</u> + 2} | Branch if greater than zero                                    |

| ВНІ | BHI <u>disp</u>             | REL        | 2 | \$22 | 4 | - | - | - | - | -    | - | (C ∨ Z == 0) ?<br>{[PC] ← [PC] + disp + 2}                                       | Branch if Accumulator contents higher than comparand          |
|-----|-----------------------------|------------|---|------|---|---|---|---|---|------|---|----------------------------------------------------------------------------------|---------------------------------------------------------------|
|     | BIT <u>A</u> # <u>data8</u> | <u>IMM</u> | 2 | \$85 | 2 |   |   |   |   |      |   | [ <u>A</u> ] <u>∧</u> <u>data8</u>                                               |                                                               |
|     | BIT <u>A</u> addr8          | DIR        | 2 | \$95 | 3 |   |   |   |   |      |   | [A] <u>∧</u> [addr8]                                                             |                                                               |
|     | BIT <u>A</u> <u>data8,X</u> | <u>IDX</u> | 2 | \$A5 | 5 |   |   |   |   |      |   | [ <u>A</u> ] <u>∧</u> [ <u>data8</u> + [ <u>X</u> ]]                             |                                                               |
|     | BIT <u>A</u> <u>addr16</u>  | EXT        | 3 | \$B5 | 4 |   |   |   |   |      |   | [ <u>A</u> ] <u>∧</u> [ <u>addr16</u> ]                                          | Memory contents AND the                                       |
| BIT | BIT <u>B</u> # <u>data8</u> | <u>IMM</u> | 2 | \$C5 | 2 | - | X | X | 0 | )  - | - | [ <u>B</u> ] <u>∧</u> <u>data8</u>                                               | Accumulator, but only Status register is affected.            |
|     | BIT <u>B</u> addr8          | <u>DIR</u> | 2 | \$D5 | 3 |   |   |   |   |      |   | [ <u>B</u> ] <u>∧</u> [addr8]                                                    |                                                               |
|     | BIT <u>B</u> <u>data8,X</u> | <u>IDX</u> | 2 | \$E5 | 5 |   |   |   |   |      |   | [ <u>B</u> ] <u>∧</u> [ <u>data8</u> + [ <u>X</u> ]]                             |                                                               |
|     | BIT <u>B</u> addr16         | <u>EXT</u> | 3 | \$F5 | 4 |   |   |   |   |      |   | [ <u>B</u> ] <u>∧</u> [addr16]                                                   |                                                               |
| BLE | BLE <u>disp</u>             | REL        | 2 | \$2F | 4 | - | - | _ | - | -    | - | (Z <u>∨</u> (S <u>∨</u> O) == 1) ?<br>{[ <u>PC</u> ] ← [ <u>PC</u> ] + disp + 2} | Branch if less than or equal to zero                          |
| BLS | BLS <u>disp</u>             | REL        | 2 | \$23 | 4 | - | - | _ | - | -    | - | (C ∨ Z == 1) ?<br>{[PC] ← [PC] + disp + 2}                                       | Branch if Accumulator contents less than or same as comparand |
| BLT | BLT <u>disp</u>             | REL        | 2 | \$2D | 4 | - | - | - | - | -    | - | (S ⊻ O == 1) ?<br>{[PC] ← [PC] + disp + 2}                                       | Branch if less than zero                                      |

| BMI   | BMI <u>disp</u>   | REL        | 2 | \$2B | 4 |   | _ | _ |   |   |   | (S == 1) ?                                                                                                                                                                                                                                                                         | Branch if minus                                                                                |
|-------|-------------------|------------|---|------|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| DIVII | Divii <u>disp</u> | IXLL       |   | φΖΟ  | 4 | F | F | Ē | Ē | - | F | {[PC] ← [PC] + disp + 2}                                                                                                                                                                                                                                                           | Dianon ii miilus                                                                               |
| BNE   | BNE disp          | REL        | 2 | \$26 | 4 | - | - | - | - | - | - | (Z == 0) ?<br>{[PC] ← [PC] + disp + 2}                                                                                                                                                                                                                                             | Branch if not equal to zero                                                                    |
| BPL   | BPL <u>disp</u>   | <u>REL</u> | 2 | \$2A | 4 | - | - | - | - | - | - | (S == 0) ?<br>{[ <u>PC</u> ] ← [ <u>PC</u> ] + <u>disp</u> + 2}                                                                                                                                                                                                                    | Branch if plus                                                                                 |
| BRA   | BRA <u>disp</u>   | REL        | 2 | \$20 | 4 | - | - | - | - | - | - | [ <u>PC</u> ] ← [ <u>PC</u> ] + <u>disp</u> + 2                                                                                                                                                                                                                                    | Unconditional branch relative to present Program Counter contents.                             |
| BSR   | BSR <u>disp</u>   | <u>REL</u> | 2 | \$8D | 8 | - | - | - | - | _ | - | $\begin{aligned} & [[\underline{SP}]] \leftarrow [\underline{PC(LO)}], \\ & [[\underline{SP}] - 1] \leftarrow [\underline{PC(HI)}], \\ & [\underline{SP}] \leftarrow [\underline{SP}] - 2, \\ & [\underline{PC}] \leftarrow [\underline{PC}] + \underline{disp} + 2 \end{aligned}$ | Unconditional branch to subroutine located relative to present Program Counter contents.       |
| BVC   | BVC disp          | REL        | 2 | \$28 | 4 | - | - | - | - | - | - | (O == 0) ?<br>{[PC] ← [PC] + disp + 2}                                                                                                                                                                                                                                             | Branch if overflow clear                                                                       |
| BVS   | BVS <u>disp</u>   | REL        | 2 | \$29 | 4 | - | - | - | - | - | - | (O == 1) ?<br>$\{[\underline{PC}] \leftarrow [\underline{PC}] + \underline{disp} + 2\}$                                                                                                                                                                                            | Branch if overflow set                                                                         |
| СВА   | СВА               | <u>INH</u> | 1 | \$11 | 2 | x | x | x | х | - | - | [A] - [B]                                                                                                                                                                                                                                                                          | Compare contents of Accumulators <u>A</u> and <u>B</u> . Only the Status register is affected. |
| CLC   | CLC               | <u>INH</u> | 1 | \$0C | 2 | 0 | _ | _ | _ | _ | _ | C <u>←</u> 0                                                                                                                                                                                                                                                                       | Clear the Carry Flag                                                                           |

| CLI | CLI                         | <u>INH</u> | 1 | \$0E | 2 | - | _ | - | - | -    | 0 | I <u>←</u> 0                                  | Clear the Interrupt flag to enable interrupts                 |
|-----|-----------------------------|------------|---|------|---|---|---|---|---|------|---|-----------------------------------------------|---------------------------------------------------------------|
|     | CLR <u>A</u>                | ACC        | 1 | \$4F | 2 |   |   |   |   |      |   | [ <u>A</u> ] <u>←</u> 0                       |                                                               |
|     | CLR <u>B</u>                | <u>ACC</u> | 1 | \$5F | 2 |   |   |   |   |      |   | [ <u>B</u> ] <u>←</u> 0                       | Clear the Accumulator                                         |
| CLR | CLR <u>data8,X</u>          | <u>IDX</u> | 2 | \$6F | 7 | 0 | 1 | 0 | 0 | )  - | - | [ <u>data8</u> + [X]] <u>←</u> 0              |                                                               |
|     | CLR <u>addr16</u>           | <u>EXT</u> | 3 | \$7F | 6 |   |   |   |   |      |   | [ <u>addr16]</u> <u>←</u> 0                   | Clear the Memory location                                     |
| CLV | CLV                         | <u>INH</u> | 1 | \$0A | 2 | _ | - | _ | 0 | ) -  | _ | O <u>←</u> 0                                  | Clear the Overflow flag                                       |
|     | CMP <u>A</u> # <u>data8</u> | <u>IMM</u> | 2 | \$81 | 2 |   |   |   |   |      |   | [ <u>A</u> ] - <u>data8</u>                   |                                                               |
|     | CMP <u>A</u> addr8          | <u>DIR</u> | 2 | \$91 | 3 |   |   |   |   |      |   | [ <u>A</u> ] - [ <u>addr8]</u>                |                                                               |
|     | CMP <u>A</u> data8,X        | <u>IDX</u> | 2 | \$A1 | 5 |   |   |   |   |      |   | [ <u>A</u> ] - [ <u>data8</u> + [ <u>X]]</u>  |                                                               |
|     | CMP <u>A</u> addr16         | <u>EXT</u> | 3 | \$B1 | 4 |   |   |   |   |      |   | [A] - [addr16]                                | Compare the contents of                                       |
| СМР | CMP <u>B</u> # <u>data8</u> | <u>IMM</u> | 2 | \$C1 | 2 | X | X | X | х | -    | - | [ <u>B</u> ] - <u>data8</u>                   | Memory and Accumulator. Only the Status register is affected. |
|     | CMP <u>B</u> addr8          | <u>DIR</u> | 2 | \$D1 | 3 |   |   |   |   |      |   | [ <u>B</u> ] - [ <u>addr8</u> ]               |                                                               |
|     | CMP <u>B</u> <u>data8,X</u> | <u>IDX</u> | 2 | \$E1 | 5 |   |   |   |   |      |   | [ <u>B</u> ] - [ <u>data8</u> + [ <u>X</u> ]] |                                                               |
|     | CMP <u>B</u> addr16         | <u>EXT</u> | 3 | \$F1 | 4 |   |   |   |   |      |   | [B] - [addr16]                                |                                                               |

|     |                     | T          | T | 1    | T | т- |   |   | Т | T |   |                                                                                                 |                                          |
|-----|---------------------|------------|---|------|---|----|---|---|---|---|---|-------------------------------------------------------------------------------------------------|------------------------------------------|
|     | COM <u>A</u>        | ACC        | 1 | \$43 | 2 |    |   |   |   |   |   | [ <u>A] ←</u> \$FF - [ <u>A]</u>                                                                | -                                        |
|     | COM B               | ACC        | 1 | \$53 | 2 |    |   |   |   |   |   | [ <u>B</u> ] <u>←</u> \$FF - [ <u>B</u> ]                                                       | Complement the Accumulator               |
| СОМ | COM <u>data8,X</u>  | <u>IDX</u> | 2 | \$63 | 7 | 1  | X | x | 0 | - | - | [ <u>data8</u> + [ <u>X]] ←</u> \$FF -<br>[ <u>data8</u> + [ <u>X]]</u>                         | Complement the Memory                    |
|     | COM <u>addr16</u>   | EXT        | 3 | \$73 | 6 |    |   |   |   |   |   | [ <u>addr16] ←</u> \$FF - [ <u>addr16</u> ]                                                     | Location                                 |
|     | CPX <u>addr8</u>    | DIR        | 2 | \$9C | 4 |    |   |   |   |   |   | [ <u>X(HI)]</u> - [ <u>addr8],</u><br>[ <u>X(LO)]</u> - [ <u>addr8</u> + 1]                     | -                                        |
|     | CPX <u>data8,X</u>  | <u>IDX</u> | 2 | \$AC | 6 |    |   |   |   |   |   | [ <u>X(HI)]</u> - [ <u>data8</u> + [ <u>X]],</u><br>[ <u>X(LO)] - [data8</u> + [ <u>X]</u> + 1] | Compare the contents of                  |
| CPX | CPX # <u>data16</u> | <u>IMM</u> | 3 | \$8C | 3 | -  | X | X | X | - | - | [X(HI)] - <u>data16(HI),</u><br>[X(LO)] - <u>data16(LO)</u>                                     | Memory to the Index<br>Register <u>X</u> |
|     | CPX <u>addr16</u>   | EXT        | 3 | \$BC | 5 |    |   |   |   |   |   | [X(HI)] - [addr16(HI)],<br>[X(LO)] - [addr16(LO)]                                               |                                          |
| DAA | DAA                 | <u>INH</u> | 1 | \$19 | 2 | x  | x | x | x | - | - |                                                                                                 | Decimal Adjust<br>Accumulator <u>A</u>   |
|     | DEC <u>A</u>        | ACC        | 1 | \$4A | 2 |    |   |   |   |   |   | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] - 1                                                          |                                          |
| DEC | DEC B               | <u>ACC</u> | 1 | \$5A | 2 | -  | X | X | X | - | - | [ <u>B] ←</u> [ <u>B</u> ] - 1                                                                  | Decrement the Accumulator                |

|     | DEC addr16                  | <u>IDX</u> | 2 | \$6A<br>\$7A | 7 | _ |   |   |   |   |   | [data8 + [X]] ← [data8 + [X]] - 1                                          | Decrement the Memory<br>Location         |
|-----|-----------------------------|------------|---|--------------|---|---|---|---|---|---|---|----------------------------------------------------------------------------|------------------------------------------|
|     | DEC <u>addr16</u>           | EXT        |   |              |   |   |   |   |   |   |   | [ <u>addr16</u> ] <u>←</u> [ <u>addr16</u> ] - 1                           |                                          |
| DES | DES                         | <u>INH</u> | 1 | \$34         | 4 | - | - | - | - | - | - | [ <u>SP</u> ] <u>←</u> [ <u>SP</u> ] - 1                                   | Decrement the Stack Pointer              |
| DEX | DEX                         | <u>INH</u> | 1 | \$09         | 4 | - | x | - | - | - | - | [ <u>X</u> ] <u>←</u> [ <u>X</u> ] - 1                                     | Decrement the Index<br>Register <u>X</u> |
|     | EOR <u>A</u> # <u>data8</u> | <u>IMM</u> | 2 | \$88         | 2 |   |   |   |   |   |   | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] <u>⊻</u> <u>data8</u>                   | -                                        |
|     | EOR <u>A</u> addr8          | DIR        | 2 | \$98         | 3 |   |   |   |   |   |   | [A] <u>←</u> [A] <u>⊻</u> [addr8]                                          |                                          |
|     | EOR <u>A</u> data8,X        | <u>IDX</u> | 2 | \$A8         | 5 |   |   |   |   |   |   | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] <u>⊻</u> [ <u>data8</u> + [ <u>X</u> ]] |                                          |
|     | EOR <u>A</u> addr16         | EXT        | 3 | \$B8         | 4 |   |   |   |   |   |   | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] <u>⊻</u> [ <u>addr16]</u>               | Memory contents                          |
| EOR | EOR <u>B</u> # <u>data8</u> | <u>IMM</u> | 2 | \$C8         | 2 | - | Х | X | 0 | - | - | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] <u>⊻</u> <u>data8</u>                   | EXLCLUSIVE OR the Accumulator            |
|     | EOR <u>B</u> addr8          | DIR        | 2 | \$D8         | 3 |   |   |   |   |   |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] <u>⊻</u> [ <u>addr8</u> ]               |                                          |
|     | EOR <u>B</u> data8,X        | <u>IDX</u> | 2 | \$E8         | 5 |   |   |   |   |   |   | [ <u>B</u> ] <u>← [B] ⊻ [data8</u> + [ <u>X]]</u>                          |                                          |
|     | EOR <u>B</u> addr16         | EXT        | 3 | \$F8         | 4 |   |   |   |   |   |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] <u>⊻</u> [ <u>addr16</u> ]              |                                          |
| INC | INC A                       | <u>ACC</u> | 1 | \$4C         | 2 | _ | X | x | x | _ | - | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] + 1                                     | Increment the Accumulator                |

|     | INC <u>B</u>                | <u>ACC</u> | 1 | \$5C | 2 |   |   |   |   |   |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] + 1                                                                                                                                                                                                                       |                                          |
|-----|-----------------------------|------------|---|------|---|---|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
|     | INC data8,X                 | <u>IDX</u> | 2 | \$6C | 7 |   |   |   |   |   |   | [ <u>data8</u> + [ <u>X]</u> ] <u>← [data8</u> + [ <u>X]]</u><br>+ 1                                                                                                                                                                                         | Increment the Memory                     |
|     | INC addr16                  | EXT        | 3 | \$7C | 6 |   |   |   |   |   |   | [ <u>addr16</u> ] <u>←</u> [ <u>addr16</u> ] + 1                                                                                                                                                                                                             | Location                                 |
| INS | INS                         | <u>INH</u> | 1 | \$31 | 4 | _ | - | - | _ | _ | - | [ <u>SP]</u>                                                                                                                                                                                                                                                 | Increment the Stack Pointer              |
| INX | INX                         | <u>INH</u> | 1 | \$08 | 4 | - | X | - | - | - | - | [ <u>X</u> ] <u>←</u> [ <u>X</u> ] + 1                                                                                                                                                                                                                       | Increment the Index<br>Register <u>X</u> |
|     | JMP <u>data8,X</u>          | <u>IDX</u> | 2 | \$6E | 4 | - |   |   |   |   |   | [ <u>PC] ← data8</u> + [ <u>X</u> ]                                                                                                                                                                                                                          |                                          |
| JMP | JMP <u>addr16</u>           | EXT        | 3 | \$7E | 3 | - | - | - | - | - | - | [ <u>PC</u> ] <u>←</u> <u>addr16</u>                                                                                                                                                                                                                         | Jump                                     |
|     | JSR <u>data8,X</u>          | <u>IDX</u> | 2 | \$AD | 8 |   |   |   |   |   |   | [[SP]] ← [PC(LO)],<br>[[SP] - 1] ← [PC(HI)],<br>[SP] ← [SP] - 2,<br>[PC] ← data8 + [X]                                                                                                                                                                       |                                          |
| JSR | JSR <u>addr16</u>           | <u>EXT</u> | 3 | \$BD | 9 | _ | - | - | _ | _ | _ | $\begin{array}{l} [[\underline{SP}]] & \leftarrow [\underline{PC(LO)}], \\ [[\underline{SP}] - 1] & \leftarrow [\underline{PC(HI)}], \\ [\underline{SP}] & \leftarrow [\underline{SP}] - 2, \\ [\underline{PC}] & \leftarrow \underline{addr16} \end{array}$ | Jump to Subroutine                       |
| LDA | LDA <u>A</u> # <u>data8</u> | IMM        | 2 | \$86 | 2 | _ | x | x | 0 | _ | _ | [ <u>A</u> ] <u>←</u> <u>data8</u>                                                                                                                                                                                                                           | Load Accumulator from                    |
|     | LDA <u>A</u> addr8          | DIR        | 2 | \$96 | 3 |   |   | , |   |   |   | [ <u>A</u> ] <u>←</u> [addr8]                                                                                                                                                                                                                                | Memory                                   |

|     | LDA <u>A</u> data8,X        | <u>IDX</u> | 2 | \$A6 | 5 |   |   |     |   |   | [A] <u>←</u> [data8 + [X]]                                                                |                         |
|-----|-----------------------------|------------|---|------|---|---|---|-----|---|---|-------------------------------------------------------------------------------------------|-------------------------|
|     | LDA <u>A</u> addr16         | EXT        | 3 | \$B6 | 4 |   |   |     |   |   | [ <u>A]</u>                                                                               |                         |
|     | LDA <u>B</u> # <u>data8</u> | <u>IMM</u> | 2 | \$C6 | 2 |   |   |     |   |   | [ <u>B] ← data8</u>                                                                       |                         |
|     | LDA <u>B</u> <u>addr8</u>   | DIR        | 2 | \$D6 | 3 |   |   |     |   |   | [ <u>B</u> ] <u>←</u> [ <u>addr8</u> ]                                                    |                         |
|     | LDA <u>B</u> data8,X        | <u>IDX</u> | 2 | \$E6 | 5 |   |   |     |   |   | [ <u>B]</u>                                                                               |                         |
|     | LDA <u>B</u> addr16         | EXT        | 3 | \$F6 | 4 |   |   |     |   |   | [ <u>B</u> ] <u>←</u> [ <u>addr16</u> ]                                                   |                         |
|     | LDS <u>addr8</u>            | DIR        | 2 | \$9E | 4 |   |   |     |   |   | [ <u>SP(HI)] ← [addr8],</u><br>[ <u>SP(LO)] ← [addr8</u> + 1]                             |                         |
|     | LDS <u>data8,X</u>          | <u>IDX</u> | 2 | \$AE | 6 |   |   |     |   |   | [ <u>SP(HI)] ← [data8</u> + [ <u>X]],</u><br>[ <u>SP(LO)] ← [data8</u> + [ <u>X]</u> + 1] |                         |
| LDS | LDS # <u>data16</u>         | <u>IMM</u> | 3 | \$8E | 3 | - | X | x ( | 0 | - | [ <u>SP(HI)] ← data16(HI),</u><br>[ <u>SP(LO)] ← data16(LO)</u>                           | Load the Stack Pointer  |
|     | LDS <u>addr16</u>           | <u>EXT</u> | 3 | \$BE | 5 |   |   |     |   |   | [SP(HI)] ← [addr16(HI)],<br>[SP(LO)] ← [addr16(LO)]                                       |                         |
|     | LDX <u>addr8</u>            | DIR        | 2 | \$DE | 4 |   |   |     |   |   | [ <u>X(HI)] ←</u> [ <u>addr8],</u><br>[ <u>X(LO)] ← [addr8</u> + 1]                       |                         |
| LDX | LDX <u>data8,X</u>          | <u>IDX</u> | 2 | \$EE | 6 | - | X | X ( | 0 | - | [X(HI)] ← [data8 + [X]],<br>[X(LO)] ← [data8 + [X] + 1]                                   | Load the Index Register |

|     | LDX #data16                 | <u>IMM</u> | 3 | \$CE | 3 |   |            |      |       |      |   |   | [X(HI)] ← data16(HI),<br>[X(LO)] ← data16(LO)                        |                                   |
|-----|-----------------------------|------------|---|------|---|---|------------|------|-------|------|---|---|----------------------------------------------------------------------|-----------------------------------|
|     | LDX addr16                  | EXT        | 3 | \$FE | 5 |   |            |      |       |      |   |   | [X(HI)] ← [addr16(HI)],<br>[X(LO)] ← [addr16(LO)]                    |                                   |
|     | LSR <u>A</u>                | ACC        | 1 | \$44 | 2 |   |            |      |       |      |   |   |                                                                      |                                   |
|     | LSR <u>B</u>                | <u>ACC</u> | 1 | \$54 | 2 |   |            |      |       |      |   |   |                                                                      | Logical Shift Right. Bit 7 is set |
| LSR | LSR <u>data8,X</u>          | <u>IDX</u> | 2 | \$64 | 7 |   | <b>(</b> ) | c C  | )   : | x  - | - | - | $0 \to \boxed{76543210} \to C$                                       | to 0.<br>(dividing by two)        |
|     | LSR <u>addr16</u>           | EXT        | 3 | \$74 | 6 |   |            |      |       |      |   |   |                                                                      |                                   |
|     | NEG <u>A</u>                | <u>ACC</u> | 1 | \$40 | 2 |   |            |      |       |      |   |   | [ <u>A</u> ] <u>←</u> 0 - [ <u>A</u> ]                               |                                   |
|     | NEG <u>B</u>                | <u>ACC</u> | 1 | \$50 | 2 |   |            |      |       |      |   |   | [ <u>B</u> ] <u>←</u> 0 - [ <u>B</u> ]                               | Negate the Accumulator            |
| NEG | NEG <u>data8,X</u>          | <u>IDX</u> | 2 | \$60 | 7 | > | <b>(</b> ) | < x  | ( )   | x .  | - | - | [ <u>data8</u> + [ <u>X]] ←</u> 0 - [ <u>data8</u> +<br>[ <u>X]]</u> | Nagata the Memory Location        |
|     | NEG <u>addr16</u>           | EXT        | 3 | \$70 | 6 |   |            |      |       |      |   |   | [ <u>addr16]</u>                                                     | Negate the Memory Location        |
| NOP | NOP                         | <u>INH</u> | 1 | \$01 | 2 |   | .  -       | .  - |       |      | - | - |                                                                      | No Operation                      |
| ORA | ORA <u>A</u> # <u>data8</u> | <u>IMM</u> | 2 | \$8A | 2 |   | . ,        | ( x  | (     | 0 -  | _ | _ | [A] <u>←</u> [A] <u>∨</u> <u>data8</u>                               | OR the Accumulator                |
|     | ORA <u>A</u> <u>addr8</u>   | DIR        | 2 | \$9A | 3 |   |            |      |       |      |   |   | [A] <u>←</u> [A] ⊻ [addr8]                                           | 2.1.0.12.1.000                    |

|     | ORA <u>A</u> data8,X        | <u>IDX</u> | 2 | \$AA | 5 |   |   |   |   |   |   | [ <u>A] ← [A] ⊻ [data8</u> + [ <u>X]]</u>                         |                                     |
|-----|-----------------------------|------------|---|------|---|---|---|---|---|---|---|-------------------------------------------------------------------|-------------------------------------|
|     | ORA <u>A</u> addr16         | <u>EXT</u> | 3 | \$BA | 4 |   |   |   |   |   |   | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] <u>∨</u> [ <u>addr16</u> ]     |                                     |
|     | ORA <u>B</u> # <u>data8</u> | <u>IMM</u> | 2 | \$CA | 2 |   |   |   |   |   |   | [B] <u>←</u> [B] <u>∨</u> <u>data8</u>                            | -                                   |
|     | ORA <u>B</u> <u>addr8</u>   | <u>DIR</u> | 2 | \$DA | 3 |   |   |   |   |   |   | [B] ← [B] <u>∨</u> [addr8]                                        |                                     |
|     | ORA <u>B</u> data8,X        | <u>IDX</u> | 2 | \$EA | 5 |   |   |   |   |   |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] <u>∨</u> [ <u>data8</u> + [X]] | -                                   |
|     | ORA <u>B</u> addr16         | EXT        | 3 | \$FA | 4 |   |   |   |   |   |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] <u>∨</u> [addr16]              |                                     |
|     | PSH <u>A</u>                | ACC        | 1 | \$36 | 4 |   |   |   |   |   |   | [[ <u>SP]] ← [A], [SP] ← [SP]</u> - 1                             | -                                   |
| PSH | PSH <u>B</u>                | <u>ACC</u> | 1 | \$37 | 4 | - | - | - | - | - | - | [ <u>[SP]] ← [B],</u><br>[ <u>SP] ← [SP]</u> - 1                  | Push Accumulator onto the Stack     |
|     | PUL <u>A</u>                | ACC        | 1 | \$32 | 4 |   |   |   |   |   |   | [ <u>SP] ← [SP]</u> + 1, [ <u>A] ← [[SP]]</u>                     |                                     |
| PUL | PUL <u>B</u>                | <u>ACC</u> | 1 | \$33 | 4 | - | - | - | - | - | - | [ <u>SP] ← [SP]</u> + 1,<br>[ <u>B] ← [[SP]]</u>                  | Pull Data from Stack to Accumulator |
|     | ROL <u>A</u>                | <u>ACC</u> | 1 | \$49 | 2 |   |   |   |   |   |   |                                                                   |                                     |
| ROL | ROL <u>B</u>                | <u>ACC</u> | 1 | \$59 | 2 | х | X | X | Х | - | - | C ← 76543210 ← C                                                  | Rotate left through Carry.          |
|     | ROL <u>data8,X</u>          | <u>IDX</u> | 2 | \$69 | 7 |   |   |   |   |   |   |                                                                   |                                     |

|     | ROL addr16                  | EXT        | 3 | \$79         | 6  |   |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                       |
|-----|-----------------------------|------------|---|--------------|----|---|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
|     | NOL <u>addi 10</u>          | LXI        | 3 | Ψίσ          |    |   |   |   |   |   | H |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                       |
|     | ROR <u>A</u>                | <u>ACC</u> | 1 | \$46         | 2  | - |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                       |
|     | ROR <u>B</u>                | <u>ACC</u> | 1 | \$56         | 2  |   |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                       |
| ROR | ROR data8,X                 | <u>IDX</u> | 2 | \$66         | 7  | x | X | х | х | - | - | $C \to 76543210 \to C$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Rotate right through Carry.                                                           |
|     |                             |            |   |              |    |   |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                       |
|     | ROR addr16                  | EXT        | 3 | \$76         | 6  |   |   | H |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                       |
| RTI | RTI                         | <u>INH</u> | 1 | \$3B         | 10 | x | X | x | X | x | x | $\begin{array}{l} [\underline{SR}] & \leftarrow [[\underline{SP}] + 1], \\ [\underline{B}] & \leftarrow [[\underline{SP}] + 2], \\ [\underline{A}] & \leftarrow [[\underline{SP}] + 3], \\ [\underline{X(HI)}] & \leftarrow [[\underline{SP}] + 4], \\ [\underline{X(LO)}] & \leftarrow [[\underline{SP}] + 5], \\ [\underline{PC(HI)}] & \leftarrow [[\underline{SP}] + 6], \\ [\underline{PC(LO)}] & \leftarrow [[\underline{SP}] + 7], \\ [\underline{SP}] & \leftarrow [\underline{SP}] + 7 \end{array}$ | Return from interrupt. Put registers from Stack and increment Stack Pointer.          |
| RTS | RTS                         | <u>INH</u> | 1 | \$39         | 5  | - | - | - | - | - | - | [ <u>PC(HI)</u> ] <u>←</u> [[ <u>SP</u> ] + 1],<br>[ <u>PC(LO)</u> ] <u>←</u> [[ <u>SP</u> ] + 2],<br>[ <u>SP</u> ] <u>←</u> [ <u>SP</u> ] + 2                                                                                                                                                                                                                                                                                                                                                               | Return from subroutine. Pull <u>PC</u> from top of Stack and increment Stack Pointer. |
| SBA | SBA                         | <u>INH</u> | 1 | \$10         | 2  | x | x | x | x | - | - | [A] ← [A] - [B]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Subtract contents of Accumulator <u>B</u> from those of Accumulator <u>A</u> .        |
| SBC | SBC <u>A</u> # <u>data8</u> | IMM<br>DIR | 2 | \$82<br>\$92 | 3  | x | x | x | x | _ | - | [A] ← [A] - <u>data8</u> - C [A] ← [A] - [ <u>addr8</u> ] - C                                                                                                                                                                                                                                                                                                                                                                                                                                                | Subtract Mem and Carry Flag from Accumulator                                          |

|     | SBC <u>A</u> data8,X        | <u>IDX</u> | 2 | \$A2 | 5 | - |   |   |   |       |   | [ <u>A</u> ] ← [ <u>A</u> ] - [ <u>data8</u> + [ <u>X</u> ]] - C        | _                                            |
|-----|-----------------------------|------------|---|------|---|---|---|---|---|-------|---|-------------------------------------------------------------------------|----------------------------------------------|
|     | SBC <u>A</u> addr16         | EXT        | 3 | \$B2 | 4 |   |   |   |   |       |   | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] - [ <u>addr16</u> ] - C              | _                                            |
|     | SBC <u>B</u> #data8         | <u>IMM</u> | 2 | \$C2 | 2 |   |   |   |   |       |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] - <u>data8</u> - C                   |                                              |
|     | SBC <u>B</u> addr8          | <u>DIR</u> | 2 | \$D2 | 3 |   |   |   |   |       |   | [ <u>B</u> ] <u>← [B</u> ] - [ <u>addr8</u> ] - C                       | _                                            |
|     | SBC <u>B</u> data8,X        | <u>IDX</u> | 2 | \$E2 | 5 |   |   |   |   |       |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] - [ <u>data8</u> + [ <u>X</u> ]] - C | _                                            |
|     | SBC <u>B</u> addr16         | EXT        | 3 | \$F2 | 4 |   |   |   |   |       |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] - [ <u>addr16</u> ] - C              |                                              |
| SEC | SEC                         | <u>INH</u> | 1 | \$0D | 2 | 1 | - | - | - | -     | _ | C <u>←</u> 1                                                            | Set the Carry Flag                           |
| SEI | SEI                         | <u>INH</u> | 1 | \$0F | 2 | - | - | - | - | -     | 1 | I <u>←</u> 1                                                            | Set the Interrupt Flag to disable interrupts |
| SEV | SEV                         | <u>INH</u> | 1 | \$0B | 2 | - | - | - | 1 | _     | _ | O <u>←</u> 1                                                            | Set the Overflow Flag                        |
|     | STA <u>A</u> addr8          | DIR        | 2 | \$97 | 4 |   |   |   |   |       |   | [addr8] ← [A]                                                           |                                              |
|     | STA <u>A</u> data8,X        | <u>IDX</u> | 2 | \$A7 | 6 |   |   |   |   |       |   | [data8 + [X]] <u>←</u> [A]                                              | _                                            |
| STA | STA <u>A</u> <u>addr16</u>  | <u>EXT</u> | 3 | \$B7 | 5 | - | x | x | 0 | )   - | - | [addr16] <u>←</u> [A]                                                   | Store Accumulator in Memory                  |
|     | STA <u>B</u> <u>addr8</u>   | <u>DIR</u> | 2 | \$D7 | 4 |   |   |   |   |       |   | [addr8] ← [B]                                                           |                                              |
|     | STA <u>B</u> <u>data8,X</u> | <u>IDX</u> | 2 | \$E7 | 6 |   |   |   |   |       |   | [ <u>data8</u> + [X]] <u>←</u> [ <u>B</u> ]                             |                                              |

|     | STA <u>B</u> <u>addr16</u>  | EXT        | 3 | \$F7 | 5 |   |     |   |   |   |   | [addr16] ← [B]                                                                                            |                                              |
|-----|-----------------------------|------------|---|------|---|---|-----|---|---|---|---|-----------------------------------------------------------------------------------------------------------|----------------------------------------------|
|     | STS <u>addr8</u>            | DIR        | 2 | \$9F | 5 |   |     |   |   |   |   | [ <u>addr8]</u>                                                                                           |                                              |
| STS | STS data8,X                 | <u>IDX</u> | 2 | \$AF | 7 | - | x   | x | 0 | - | - | [ <u>data8</u> + [X]] <u>←</u> [ <u>SP(HI)</u> ],<br>[ <u>data8</u> + [X] + 1] <u>←</u> [ <u>SP(LO)</u> ] | Store the Stack Pointer                      |
|     | STS <u>addr16</u>           | <u>EXT</u> | 3 | \$BF | 6 |   |     |   |   |   |   | [ <u>addr16(HI)</u> ] ← [ <u>SP(HI)</u> ],<br>[ <u>addr16(LO)</u> ] ← [ <u>SP(LO)</u> ]                   |                                              |
|     | STX <u>addr8</u>            | <u>DIR</u> | 2 | \$DF | 5 |   |     |   |   |   |   | [ <u>addr8] ← [X(HI)],</u><br>[ <u>addr8</u> + 1] <u>← [X(LO)]</u>                                        |                                              |
| STX | STX <u>data8,X</u>          | <u>IDX</u> | 2 | \$EF | 7 | - | x   | x | 0 | - | - | [ <u>data8</u> + [X]] <u>←</u> [X(HI)],<br>[ <u>data8</u> + [X] + 1] <u>←</u> [X(LO)]                     | Store the Index Register X                   |
|     | STX <u>addr16</u>           | <u>EXT</u> | 3 | \$FF | 6 |   |     |   |   |   |   | [ <u>addr16(HI)</u> ] <u>←</u> [X(HI)],<br>[ <u>addr16(LO)]</u> ← [X(LO)]                                 |                                              |
|     | SUB <u>A</u> # <u>data8</u> | <u>IMM</u> | 2 | \$80 | 2 |   |     |   |   |   |   | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] - <u>data8</u>                                                         |                                              |
|     | SUB <u>A</u> <u>addr8</u>   | DIR        | 2 | \$90 | 3 |   |     |   |   |   |   | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] - [ <u>addr8</u> ]                                                     |                                              |
| •   | SUB <u>A</u> <u>data8,X</u> | <u>IDX</u> | 2 | \$A0 | 5 | Х | x x | х | х | - | - | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] - [ <u>data8</u> + [ <u>X</u> ]]                                       | Subtract Memory contents<br>from Accumulator |
|     | SUB <u>A</u> addr16         | <u>EXT</u> | 3 | \$B0 | 4 |   |     |   |   |   |   | [ <u>A</u> ] <u>←</u> [ <u>A</u> ] - [ <u>addr16</u> ]                                                    |                                              |
|     | SUB <u>B</u> # <u>data8</u> | <u>IMM</u> | 2 | \$C0 | 2 |   |     |   |   |   |   | [ <u>B</u> ] <u>←</u> [ <u>B</u> ] - <u>data8</u>                                                         |                                              |

|     | SUB B addr8          | DIR        | 2 | \$D0 | 3  |   |   |   |   |   |   | [ <u>B</u> ] ← [ <u>B</u> ] - [ <u>addr8</u> ]                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                           |
|-----|----------------------|------------|---|------|----|---|---|---|---|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
|     |                      |            |   |      |    |   |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                           |
|     | SUB <u>B</u> data8,X | <u>IDX</u> | 2 | \$E0 | 5  | - |   |   |   |   |   | [B] ← [B] - [data8 + [X]]                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                           |
|     | SUB <u>B</u> addr16  | <u>EXT</u> | 3 | \$F0 | 4  |   |   |   |   |   |   | [B] <u>←</u> [B] - [addr16]                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                           |
| SWI | SWI                  | <u>INH</u> | 1 | \$3F | 12 | - | - | - | - | - | 1 | $\begin{split} & [[\underline{SP}]]  [\underline{PC(LO)}], \\ & [[\underline{SP}] - 1]  [\underline{PC(HI)}], \\ & [[\underline{SP}] - 2]  [\underline{X(LO)}], \\ & [[\underline{SP}] - 3]  [\underline{X(HI)}], \\ & [[\underline{SP}] - 4]  [\underline{A}], \\ & [[\underline{SP}] - 5]  [\underline{B}], \\ & [[\underline{SP}] - 6]  [\underline{SR}], \\ & [\underline{SP}]  [\underline{SP}] - 7, \\ & [\underline{PC(HI)}]  [\$FFFA], \\ & [\underline{PC(LO)}]  [\$FFFB] \end{split}$ | Software Interrupt: push registers onto Stack, decrement Stack Pointer, and jump to interrupt subroutine. |
| TAB | TAB                  | <u>INH</u> | 1 | \$16 | 2  | _ | х | х | 0 | - | - | [B] <u>←</u> [A]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Transfer <u>A</u> to <u>B</u>                                                                             |
| TAP | TAP                  | <u>INH</u> | 1 | \$06 | 2  | Х | х | х | х | х | - | [SR] ← [A]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Transfer <u>A</u> to Status Register                                                                      |
| ТВА | ТВА                  | <u>INH</u> | 1 | \$17 | 2  | _ | х | х | 0 | _ | - | [A] <u>←</u> [B]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Transfer <u>B</u> to <u>A</u>                                                                             |
| TPA | TPA                  | <u>INH</u> | 1 | \$07 | 2  | _ | _ | _ | _ | - | - | [A] <u>←</u> [SR]                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Transfer Status Register to <u>A</u>                                                                      |
|     | TST <u>A</u>         | ACC        | 1 | \$4D | 2  |   |   |   |   |   |   | <u>[A]</u> - 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                           |
| TST | TST <u>B</u>         | <u>ACC</u> | 1 | \$5D | 2  | 0 | x | x | 0 | - | - | [ <u>B</u> ] - 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Test the Accumulator                                                                                      |
|     | TST <u>data8,X</u>   | <u>IDX</u> | 2 | \$6D | 7  |   |   |   |   |   |   | [ <u>data8</u> + [X]] - 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Test the Memory Location                                                                                  |

|     | TST <u>addr16</u> | EXT        | 3 | \$7D | 6 |   |   |   |   |   |   | [ <u>addr16</u> ] - 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                          |
|-----|-------------------|------------|---|------|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TSX | TSX               | <u>INH</u> | 1 | \$30 | 4 | - | - | - | - | - | - | [X] <u>←</u> [SP] + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Move Stack Pointer contents to Index register and increment.                                                                                                                                                             |
| TXS | TXS               | <u>INH</u> | 1 | \$35 | 4 | - | - | - | - | - | - | [ <u>SP</u> ] <u>←</u> [ <u>X</u> ] - 1                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Move Index register contents to Stack Pointer and decrement.                                                                                                                                                             |
| WAI | WAI               | <u>INH</u> | 1 | \$3E | 9 | - | - | - | - | - | 1 | $\begin{array}{l} [[\underline{SP}]] \leftarrow [\underline{PC(LO)}], \\ [[\underline{SP}] - 1] \leftarrow [\underline{PC(HI)}], \\ [[\underline{SP}] - 2] \leftarrow [\underline{X(LO)}], \\ [[\underline{SP}] - 3] \leftarrow [\underline{X(HI)}], \\ [[\underline{SP}] - 4] \leftarrow [\underline{A}], \\ [[\underline{SP}] - 5] \leftarrow [\underline{B}], \\ [[\underline{SP}] - 6] \leftarrow [\underline{SR}], \\ [\underline{SP}] \leftarrow [\underline{SP}] - 7 \end{array}$ | Push registers onto Stack, decrement Stack Pointer, end wiat for interrupt. If [I] = 1 when WAI is executed, a non-maskable interrupt is required to exit the Wait state.  Otherwise, [I] — 1 when the interrupt occurs. |